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DETAILED ACTION 

1 . This action is in response to the amendment filed 6/1 8/2008. 

2. Per applicant's request, claim 1 is amended; claims 1 , 1 0-1 3, 1 6-1 8, and 25-27 
remain pending and have been considered below. 

Response to Amendment 

3. In view of applicant's amendment, the prior rejection to claim 1 under 1 1 2, 
second paragraph is hereby withdrawn. 

Response to Arguments 

4. Applicant's arguments filed 6/1 8/2008 have been fully considered but they are 
not deemed persuasive. 

Applicant asserts on page 7 of the amendment that Bentley fails to teach 
"automatically creating a class file container object" and "dynamically code 
generation." 

Examiner respectfully disagrees with the allegations as argued. Dynamically 
generating code means that the code is dynamically (i.e. at runtime) created. Bentley 
teaches "The dynamic framework executes on the platform and interfaces to the 
kernel, provides a platform-independent visual interface between the CMS and a CMS 
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user, and employs the services of the kerner (see at least col. 6:8-12). Bentley goes on 
to describe "As was discussed above, in terms of the run-time CMS 10 of the present 
embodiment' (see col. 12:36) and "At runtime, the interface declaration 66 is embodied 
in an interface object 52C for the interface 56..." (see at col. 14:10-13). In other words, 
Bentley teaches code is generated dynamically (or at runtime). Bentley further teaches 
"Preferably, the CMS 10 of the present embodiment supports the automatic reading 
and writing of all data types by the object/persistence manager 30 of the CMS kernel 
12" (see at least col. 42:27-29). This also indicates that the run-time CMS 10 supports 
the automatic and dynamic generation of code. 

Claim Rejections - 35 USC § 102 

5. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 1 02 that 
form the basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(b) the invention was patented or described in a printed publication in this or a foreign country or in public 
use or on sale in this country, more than one year prior to the date of application for patent in the United 
States. 

6. Claims 1, 12, 16, 17, 26, and 27 are rejected under 35 U.S.C. 102(b) as being 
anticipated by Bentley et al. (United States Patent No.: 5,815,415). 

As per claim 1 : 

Bentley teaches: 

computer code for creating a class file container object that stores source 
code describing a class (see at least Figures 5-7; also see at least col. 12:51-53 
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"In the programming language 53, a class declaration defines a class 54..."; 
col. 13:30-38 "class StormDoor : Door..."; col. 14:64-67 "A template 58 
provides a flexible programming language technique for declaring classes 
54..."); 

computer code for adding a first source code defining a method to the 
class stored in the class file container object (see at least Figures 5-7; also see at 
least col. 12:42-44 "a class 54 defines member variables 60 (i.e. types of 
data) common to each object 52 and methods 62 (i.e. functions) that 
operate on the member variables 60"; also see col. 13:1-5 "//Declare 
methods..."), wherein creating a class file container object includes selecting a 
class name and a super class for the class (see at least col. 1 3:1 6-25 "Classes 
54 may be derived from other classes 54. ..For example, a "StormDoor" 
class may be derived from the Door class... In such case, Door is a "base 
class" (i.e. super class or parent class)..."); 

computer code for adding a second source code into the method in the 
class stored in the class file container object (see at least Figures 5-7; also see at 
least col. 12:42-44 "a class 54 defines member variables 60 (i.e. types of 
data) common to each object 52 and methods 62 (i.e. functions) that 
operate on the member variables 60"; also see col. 13:1-5 "//Declare 
methods..."); 
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computer code for repeating instructions b and c to populate the class 
stored in the class file container object (see at least Figure 6 - There are more 
than one methods have been declared for the new class 54); 

generating a tree of statement and expressions based on the class stored 
in the class file container object (see at least Figures 25-26); 

computer code for using the tree of statements and expressions to 
generate byte code for the class (see at least col. 31 :44 "the source code is 
compiled into run-time code that may be executed on any platform 19 
having an appropriately configured run-time virtual machine"; col. 34:49-50 
"each program 96 is compiled into an efficient byte code format such as p- 
code (i.e. pseudo-code)"); and 

computer code for instantiating an instance of the new class file object 
(see at least col. 12:37-40 "a class 54 is part of a schema 50 and defines an 
object 52 that may be instantiated from the class 54..."); 

wherein the computer program product can generate code for any type of 
JAVA program ("The dynamic framework executes on the platform and 
interfaces to the kernel, provides a platform-independent visual interface 
between the CMS and a CMS user, and employs the services of the kernel" 
see at least col. 6:8-12). 



As per claim 12: 

Bentley further teaches: 
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repeatedly adding a method to the class stored in the class file container 
object for teach method associated with a stub generated for a remote object 
(see at least Figures 6 - There are more than one methods have been 
declared for the new class 54. Therefore, repeatedly adding methods to the 
new class is inherent in order to fulfill the purpose of declaration of new 
class). 

As per claim 16: 

Bentley further teaches: 

wherein the tree of statements and expressions represents at least one 
method, the at least one method comprising at least one of: a code statement, an 
expression, a variable and a programming construct (see at least Figures 25-26). 

As per claim 17: 

Bentley further teaches: 

wherein the tree of statements and expressions forms a known structure 
or interface when the class is a known type (see at least col. 12:62 "Door"; col. 
14:66 "Shell"). 



As per claim 26: 

Bentley further teaches: 
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wherein dynamically generated code exists for the life of a server it 
resides upon (it is inherent in order to fulfill the purpose of runtime class 
generation). 



As per claim 27: 

Bentley further teaches: 

computer code for generating executable code from the byte code by 
using a class loader (see at least col. 38:25-26 "a loader must convert the data 
to the format required for the platform 19 where the program 96 will run"). 



Claim Rejections - 35 USC § 103 

7. The following is a quotation of 35 U.S.C. 1 03(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

8. ClaimslO and 18 are rejected under 35 U.S.C. 103(a) as being unpatentable 
over Bentley et al. (United States Patent No.: 5,815,415), in view of Click, Jr. et al. 
(United States patent No.: US 6,381 ,737). 



As per claim 10: 

Bentley does not explicitly teach: 

wherein the computer code implements an adaptor class. 
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However, Click, Jr. teaches: 

wherein the program code implements an adaptor class (see at least col. 

3:20-21 "The computer code also generates an adapter when requested by 

the runtime system in order to execute the bytecode "). 

Therefore, it would have been obvious to one having an ordinary skill in the art at 
the time the invention was made to modify Bentley's approach to dynamically build an 
adapter class as taught be Click, Jr. One would have been motivated to generate an 
adapter class as taught by Click, Jr. to execute the generated byte code. 

As per claim 18: 

Bentley in combination with Click, Jr. teaches all the limitations of the base claim, 
furthermore, Bentley in combination with Click, Jr. further teaches: 

wherein the tree of statements and expressions forms a known structure 
when the class is at least one of an adapter and a proxy type (see Click, Jr. at 
least col. 3:20 "an adapter"). 

9. Claim 1 1 is rejected under 35 U.S.C. 103(a) as being unpatentable over Bentley 
et al. (United States Patent No.: 5,815,415), in view of Glynias et al. (United States 
Patent No.: 6,125,383). 



As per claim 1 1 : 

Bentley does not explicitly teach: 
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wherein the computer code implements a proxy class. 
However, Glynias teaches: 

wherein the computer code implements an adaptor class (see at least col. 
15:35-36 "The client 110 would invoke a Java applet to create a proxy 
object, called "DNA Sequence ADH_Human "). 

Therefore, it would have been obvious to one having an ordinary skill in the art at 
the time the invention was made to modify Bentley's approach to dynamically create a 
proxy class as taught by Glynias. One would have been motivated to modify because 
proxy class can be used to create another object (see Glynias at least col. 15:40-45). 

10. Claim 13 is rejected under 35 U.S.C. 103(a) as being unpatentable over Bentley 
et al. (United States Patent No.: 5,815,415). 

As per claim 13: 

Bentley does not explicitly teach: 

wherein the computer code for repeatedly adding a method to the class 
stored in the class file container object for each method associated with a stub 
generated for a remote object includes program code for: 

determining a number of methods associated with the stub in a 
remote interface. 

However, official notice is taken that determine the number of methods is well 
known to the art at the time the invention was made and modify Bentley's approach to 
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count the number of method declared for the class by using a counter variable. One 
would have been motivated to modify because using a counter variable to count the 
number of methods added to the class provides an indication when it reaches the end of 
the adding iteration loop. 

1 1 . Claim 25 is rejected under 35 U.S.C. 103(a) as being unpatentable over Bentley 
et al. (United States Patent No.: 5,815,415), in view of Whitehead et al. (United States 
Patent No.: 6,085,030). 

As per claim 25: 

Bentley does not explicitly teach: 

wherein the dynamically generated code is used for remote method 

invocation skeletons, remote method invocation stubs, wrappers for database 

connections, and proxies used to enforce call-by-value semantics. 

However, Whitehead teaches the use of RMI, JDBC, and proxies "...RMI, i.e., 
proxy/skeleton interaction" (see col. 7:29) and "ODBC/JDBC compliant databases" 
(see col. 7:67). 

Therefore, it would have been obvious to one having an ordinary skill in the art at 
the time the invention was made to modify Bentley's approach to use RMI, JDBC, and 
proxy for remote communication with other JAVA objects and intercepting calls between 
JAVA objects. One would have been motivated to modify in order to improve 
convenience, compatibility or security. 
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Conclusion 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Phillip H. Nguyen whose telephone number is (571 ) 
270-1070. The examiner can normally be reached on Monday - Thursday 10:00 AM - 
3:00 PM EST. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Wei Y. Zhen can be reached on (571) 272-3708. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 

PN 

8/19/2008 



/Wei Y Zhen/ 

Supervisory Patent Examiner, Art Unit 2191 



